草庐IT

c++ - 64位系统的优点

全部标签

golang 操作系统/exec : get data from stdout in parts

我想使用os/exec从我的go代码运行一个外部应用程序。应用程序my_external_script.sh分两部分将数据输出到stdout:第一部分非常快(三秒后将“A”写入stdout),第二部分("B)仅在10秒后写入。例如:./my_external_script.sh..........A(3secondselapsed)..............................B(10secondselapsed)(programexitswith0statuscode)我目前正在从我的go代码中这样执行:funcexecMyExternalCmd()(*string,e

go - 如何检查操作系统上是否安装了程序/软件包?

我想用Go检查dot包是否已安装并可在当前OS上执行。我的第一个想法是检查PATH变量中的/dot字符串?有没有更好的方法来使用Go获取可执行/已安装的包?任何建议都会有所帮助,谢谢。 最佳答案 你是说一个gopackage吗?如果是这样,请尝试使用golistgithub.com/some/package 关于go-如何检查操作系统上是否安装了程序/软件包?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.

string - GOLANG 64decode字符串非法数据,不知道为什么

各位地鼠:我被困在一些简单的事情上。我正在尝试转换解码64endoded字符串(准确地说是OAUTHtoken)。我拆分字符串,并将拆分的一部分进行64位解码,但我总是发现非法字符。当我将相同的值放入任何基于Web的64位解码器时,它就起作用了。我认为可能有一个尾随的null或其他东西。谁能给我一些建议。我把代码放在这里:https://play.golang.org/p/cf-x6GgpEp确切的错误是:输入字节408处的非法base64数据下面也是代码,很短:packagemainimport("fmt""strings"b64"encoding/base64")funcmain(

c - O_NONBLOCK SOCK_STREAM 限制为 8192

我正在从C程序写入SOCK_STREAM正在从go程序监听的Unix域套接字,使用net.Listen("unix",sockname).当我将套接字设置为O_NONBLOCK使用fcntl(),我看到C程序在第一次写入时只写入了8192字节。失败后,我监控并回写剩余数据,但我服务器上读取的数据在这种情况下是无效的。当我不使用O_NONBLOCK时,然后整个8762字节被写在一个单一的写入中,一切都按预期工作。C客户端套接字连接if((fd=socket(AF_UNIX,SOCK_STREAM,0))==-1){return;}intflags=fcntl(fd,F_GETFL,0);

file - 使用 Golang 进行读取的 mmap 系统调用

我不是Go不安全包专家-我也不是经验丰富的C程序员。我正在尝试使用mmap系统调用读取一个大于1G的大文件。我使用mmap和munmap而不是读取、写入I/O的原因有很多。那不是重点-我可以在测试中写入文件,当我从文件中读取时,我可以确定字节长度匹配,但我无法读取该字符串文件的内容:(有人可以建议阅读吗?我需要做的更进一步,这是我为示例测试编写的一些代码:filename:="/tmp/dd_file.db"f,err:=os.OpenFile(filename,os.O_RDWR,0666)deferf.Close()iferr!=nil{fmt.Printf("erroropeni

c - 为什么我用cgo的时候报错 "undefined reference to ` add2”

目录如下:-包括测试.h-liblibmytest.so-源代码测试.gotest.go代码如下:packagemain/*#cgoCFLAGS:-I../include#cgoLDFLAGS:-L../lib-lmytest#include"Test.h"*/import"C"funcmain(){C.add2(10,10)}当我使用gobuildtest.go时,控制台报告:#command-line-arguments/tmp/go-build168903458/command-line-arguments/_obj/test.cgo2.o:在函数_cgo_9efddd4c1a4

golang 中的 C long double

我正在将算法从C移植到Go。我有点困惑。这是C函数:voidgauss_gen_cdf(uint64_tcdf[],longdoublesigma,intn){inti;longdoubles,d,e;//Calculations...for(i=1;i并在for循环中将值“s”分配给数组cdf中的元素“x”。这怎么可能?据我所知,longdouble是float64(在Go上下文中)。所以我不应该能够编译C代码,因为我正在将一个longdouble分配给一个只包含uint64元素的数组。但C代码运行良好。那么有人可以解释为什么这是有效的吗?非常感谢。更新:函数的原始C代码可以在这里找

c++ - 系统调用 GetLastError() 不返回错误

在golang中syscall.GetLastError()不返回最后一个错误。看下面的例子ifhandle:=_OpenSCManager(machineNamePtr,databaseNamePtr,desiredAccess);handle==nil{iferr:=syscall.GetLastError();err!=nil{returnInvalidServiceDatabaseHandleHandle,ServiceErrno(err.(syscall.Errno))}}err始终为nil。假设machineNamePtr是一台不存在的机器。使用C++测试了相同的代码,Ge

golang simplejson mustint64 不会从字符串转换为 int64

我正在使用simplejson,它提供了类型断言器。fmt.Printf("%s%s",m.Get("created_time").MustString(),m.Get("created_time").MustInt64())上面的代码显示了这个结果:1506259900%!s(int64=0)所以MustInt64()给出0而不是转换后的Int64值。是不是因为1506259900太大了无法转换?感谢您的帮助! 最佳答案 原始的json是:{"created_time":"1505733738"}不是{"created_time"

c - 如何从 Go 函数返回 C 指针?

我有疑问是否可以从C上的Go函数指针返回?例如main.c可以是:structopen_db_returndb_ptr=open_db(db_path);GoSlicebacket={"DB",2,2};GoSlicekey={"CONFIG",6,6};structget_value_returnval=get_value(db_ptr.r0,backet,key);close_db(db_ptr.r0);接下来是Go代码://exportopen_dbfuncopen_db(pathstring)(interface{},error){db,err:=db.Open(path,06